<template>
  <div class="user-wrapper">
    <div class="content-box">
      <a href="/document" target="_blank">
        <span class="action">
          <a-icon type="question-circle-o"></a-icon>
        </span>
      </a>
      <account-info class="action"/>
      <a-dropdown>
        <span class="action ant-dropdown-link user-dropdown-menu">
          <a-avatar class="avatar" size="small" src="/avatar.jpg"/>
          <span>{{ nick }}</span>
        </span>
        <a-menu slot="overlay" class="user-dropdown-menu-wrapper">
          <a-menu-item key="1">
            <router-link :to="{ name: 'settings' }">
              <a-icon type="setting"/>
              <span>账户设置</span>
            </router-link>
          </a-menu-item>
          <a-menu-divider/>
          <a-menu-item key="3">
            <a href="javascript:;" @click="handleLogout">
              <a-icon type="logout"/>
              <span>退出登录</span>
            </a>
          </a-menu-item>
        </a-menu>
      </a-dropdown>
    </div>
  </div>
</template>

<script>
import AccountInfo from '@/components/AccountInfo'
import NoticeIcon from '@/components/NoticeIcon'
import { mapActions, mapGetters } from 'vuex'
import { LOGIN_PAGE } from '@/config/constants'

export default {
  name: 'UserMenu',
  components: {
    AccountInfo,
    NoticeIcon
  },
  computed: {
    ...mapGetters(['name', 'nick', 'root', 'dept', 'role'])
  },
  methods: {
    ...mapActions(['logout']),
    handleLogout () {
      const _this = this
      this.$confirm({
        title: '提示',
        content: '真的要注销登录吗 ?',
        onOk () {
          return _this.logout({}).then(() => {
            _this.$router.push({ path: LOGIN_PAGE })
            setTimeout(() => {
              window.location.reload()
            }, 16)
          }).catch(err => {
            console.error(err)
            _this.$message.error({
              title: '错误',
              description: err.message
            })
          })
        },
        onCancel () {
        }
      })
    }
  }
}
</script>
